package org.suze.springboot.elasticsearch.service;

import org.elasticsearch.search.SearchHit;
import org.suze.springboot.elasticsearch.param.BaseSearchParam;

import java.util.List;
import java.util.Map;

/**
 * @description: 基础ElasticSearch操作接口
 * @Date : 2020/5/14 上午11:30
 * @Author : 石冬冬-Seig Heil
 */
public interface ElasticSearchService {
    /**
     * 判断索引是否存在
     * @param index
     * @return
     */
    boolean exists(String index);

    /**
     * 删除索引
     * @param indices
     * @return
     */
    boolean deleteIndex(String... indices);
    /**
     * 查询elasticsearch，适用于大批量数据查询
     * 使用scroll游标形式
     * @param param 查询参数
     * @return
     */
    List<SearchHit> queries(BaseSearchParam param);
    /**
     * 根据索引、id查询elasticsearch数据
     *
     * @param index 索引
     * @param id         id
     * @return
     */
    Map<String, Object> query(String index, String id);
}
